<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
</head>

<body>
    <h2>直接通过FormData</h2>
    <!-- e.target.files[0] -->
    <!-- 推荐用户选择 图片 -->
    <input type="file" accept="image/*" multiple/>
    <img src="" alt="" />
    <!-- 点击按钮 上传用户选择的图片 -->
    <button>上传</button>
    <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>

    <script>
        // 1.点击按钮上传图片
        document.querySelector('button').onclick = function () {
            // 2.实例化formData 默认是空的
            const data = new FormData()
            // 3. 追加数据
            // console.log(document.querySelector('input').files)
            // console.log(document.querySelector('input').files[0])
            // 获取到用户选择的文件
            const img = document.querySelector('input').files[0]
            // formData中有数据了 key:value
            // key==avatar
            // value ==选择的图片
            data.append('avatar', img)
            // console.log(data.get('avatar'))
            axios({
                url: 'http://ajax-api.itheima.net/api/file',
                method: 'post',
                data, // data:data
            }).then((res) => {
                // console.log('res:', res)
                // console.log(res.data.data.url)
                // 渲染出来
                document.querySelector('img').src = res.data.data.url
            })
        }
    </script>
</body>

</html>